<!-- ENCODER -->
<encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
<Pattern>My File Appender: %d %p %c{30} %m %n</Pattern>
</encoder>
<!-- ROLLOVER POLICY (daily and when the file reaches 1MB) -->
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<fileNamePattern>logs/archived/RollingFile_%d{dd.MM.yyyy}_%i.log</fileNamePattern>
<timeBasedFileNamingAndTriggeringPolicy
class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
<maxFileSize>10MB</maxFileSize>
</timeBasedFileNamingAndTriggeringPolicy>
</rollingPolicy>
</appender>
<!-- LOGGER -->
<logger name="com.ivoronline.springboot_log_logback_config_xml.controllers" level="INFO">
<appender-ref ref="MyConsoleAppenderName" />
<appender-ref ref="MyFileAppenderName" />
<appender-ref ref="MyRollingFileAppenderName"/>
</logger>
<!-- DISABLE DEFAULT LOGGER (since no appenders are defined) -->
<root level="info"> </root>
</configuration>
MyController.java
package com.ivoronline.springboot_log_logback_config_xml.controllers;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
@Controller
public class MyController {
Logger log = LoggerFactory.getLogger(MyController.class);
@ResponseBody
@RequestMapping("/Hello")
public String hello() {
log.error("Some error occured");
log.warn ("Some warn occured");
log.info ("Some info occured");
log.debug("Some debug occured");
log.trace("Some trace occured");
return "Hello from Controller";
}
}